IN THE CLAIMS: 

This listing of claims shall replace all prior versions, and listings, of claims 
in the application: 

1. (Currently amended) A boot method for synchronizing a real 
microcontroller and a virtual microcontroller of an In-Grcu.it Emulation system 
in lock-step, comprising: 

in the real microcontroller, executing a set of boot code to carry out 
initialization; 

in the virtual microcontroller, executing a set of timing code to enable a 
lock-step synchronization with the real microcontroller, wherein the set of timing 
code is a dummy code timed to take the same number of clock cycles as the real 
microcontroller uses to execute the set of boot code, wherein the set of timing 
code is functionally different from the set of boot code, and wherein the set of 
boot code is stored within the real microcontroller and the set of boot code is 
inaccessible to the virtual microcontroller; 

simultaneously halting both the real m icrocontroller and the virtual 
microcontroller; and 

restarting the real microcontroller and the virtual microcontroller to 
execute instructions in lock-stepped synchronization. 

2. {Currently amended) The method according to Claim 1, further 
comprising copying register contents from the real m icrocontroller to 
corresponding registers in the virtual microcontroller after completion of the 
simultaneous halting. 
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3. (Canceled) 



4. (Currently amended) The method according to Claim 1, wherein after the 
executing of the boot code, the real microcontroller branches to an assembly 
instruction line 0; and wherein after the executing the timing code, the virtual 
microcontroller branches to the assembly instruction line 0. 

5. (Previously presented) The method according to Claim 1, wherein prior 
to the executing of the boot code, and prior to the executing the timing code, a 
break is set at an assembly instruction line 0. 

6. (Previously presented) The method according to Claim 1, wherein the 
boot code comprises protected initialization code that is protected from the In- 
Circuit Emulation system. 

7. (Currently amended) The method according to Claim 1, further 
comprising: 

prior to the executing of the boot code, and prior to the executing the 
timing code, setting a break at an assembly instruction line 0, 

wherein after the executing of the boot code the real m icrocontroller 
branches to the assembly instruction line 0; and 

wherein after the executing the timing code, the virtual microcontroller 
branches to the assembly instruction line 0. 
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8. (Currently amended) The method according to Claim \, further 
comprising: 

prior to the executing of the boot code, and prior to the executing the 
timing code, setting a break at an assembly instruction lirie 0; 

wherein after the executing of the boot code, the real m icrocontroller 
branches to the assembly instruction line 0; and wherein after the executing the 
timing code, the virtual microcontroller branches to the assembly instruction line 
0; 

copying register contents from the real microcontroller to corresponding 
registers in the virtual microcontroller; and 

copying memory contents from the real m icrocontroller to corresponding 
memory in the virtual microcontroller, 

wherein after the executing of the boot code, the real microcontroller 
branches to the assembly instruction line 0; and 

wherein after the executing the timing code, the virtual microcontroller 
branches to the assembly instruction line 0. 

9. (Previously presented) The method according to Claim 8, further 
comprising removing the break at the assembly line 0 after the copying the 
register contents and the copying the memory contents. 

10. (Currently amended) A boot method for synchronizing a real 
microcontroller and a virtual microcontroller of an In-Circuit Emulation system 
in lock-step, comprising: 

resetting the real microcontroller and the virtual microcontroller to a halt 

state; 
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setting a break at an assembly instruction line 0; 
in the r eal m icrocontroller, executing a set of boot code to carry out 
initialization; 

in the virtual microcontroller, executing a set of timing code to enable a 
lock-step synchronization with the real microcontroller, wherein the set of timing 
code is a dummy code timed to take the same number of clock cycles as the real 
microcontroller uses to execute the set of boot code, wherein the set of timing 
code is functionally different from the set of boot code, and wherein the set of 
boot code is stored within the reajjmcrocontroller and the set of boot code is 
inaccessible to the virtual, microcontroller; 

simultaneously halting both the real m icrocontroller and the virtual 
microcontroller by branching to the assembly instruction line 0; 

copying register contents from the real m icrocontroller to corresponding 
registers in the virtual microcontroller; 

copying memory contents from the real microcontroller to corresponding 
memory in the virtual microcontroller; and 

removing the break at the assembly line 0 after the copying the register 
contents and the copying the memory contents. 

11. (Canceled) 

12. (Previously presented) A boot method for synchronizing a tested device 
and a virtual processor of an In-Circuit Emulation system in lock-step, 
comprising: 

in the tested device, executing a set of boot code to carry out initialization; 
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in the virtual processor, executing a set of timing code to enable a lock- 
step synchronization with the tested device, wherein the timing code is a dummy 
code timed to take the same number of clock cycles as the tested device uses to 
execute the set of boot code, wherein at least one portion of the set of timing code 
is different from the set of boot code, and wherein the set of boot code is stored 
within the tested device and the set of boot code is inaccessible to the virtual 
processor; 

simultaneously halting both the tested device and the virtual processor; 

and 

restarting the tested device and the virtual microprocessor to execute 
instructions in lock-stepped synchronization. 

13. (Canceled) 

14. (Previously presented) The method according to Claim 12, further 
comprising copying memory contents from memory coupled to the tested device 
to corresponding memory coupled to the virtual processor. 

15. (Previously presented) The method according to Claim 12, wherein after 
the executing of the boot code, the tested device branches to an assembly 
instruction line 0; and wherein after the executing the timing code, the virtual 
processor branches to the assembly instruction line 0. 

16. (Previously presented) The method according to Claim 12, wherein prior 
to the executing of the boot code, and prior to the executing the timing code, a 
break is set at an assembly instruction line 0. 
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17. (Previously presented) The method according to Claim 12, wherein the 
boot code comprises protected initialization code that is not accessible to the In- 
Circuit Emulation system.. 

18. (Previously presented) The method according to Claim 12, further 
comprising: 

prior to the executing of the boot code, and prior to the executing the 
timing code, setting a break at an assembly instruction line 0, 

wherein after the executing of the boot code, the tested device branches to 
the assembly instruction line 0; and 

wherein after the executing the timing code, the virtual processor 
branches to the assembly instruction line 0. 

19. (Previously presented) The method according to Claim 12, further 
comprising: 

prior to the executing of the boot code, and prior to the executing the 
timing code, setting a break at an assembly instruction line 0, 

wherein after the executing of the boot code, the tested device branches to 
the assembly instruction line 0; and wherein after the executing the timing code, 
the virtual processor branches to the assembly instruction line 0; 

copying register contents from the tested device to corresponding 
registers in the virtual processor; and 

copying memory contents from the tested device to corresponding 
memory in the virtual processor, 
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wherein after the executing of the boot code, the tested device branches to 
the assembly instruction line 0; and 

wherein after the executing the timing code, the virtual processor 
branches to the assembly instruction line 0. 

20. (Previously presented) The method according to Claim 19, further 
comprising removing the break at the assembly instruction line 0 after the 
copying the register contents and the copying the memory contents. 

21. (Original) The method according to Claim 12, wherein the virtual 
processor is implemented in a field programmable gate array. 

22. (Previously presented) The method according to Claim 1, wherein the set 
of boot code comprises proprietary information, wherein the proprietary 
information comprises serial numbers, passwords, and algorithms. 

23. (Currently amended) The method according to Claim 1, wherein at least 
one portion of the boot code is inaccessible to the virtual microcontroller by being 
stored internally in the real microcontroller. 

REMARKS 

Applicant respectfully requests consideration of the subject application 
as amended herein. This Amendment is submitted in response to the Office 
Action mailed on 4/20/2009. Claims 1, 2, 4-10, 12, and 14-23 are rejected. In 
this Amendment, claims 1, 2, 4, 7, 8, 10, and 23 have been amended. No new 
matter has been added. Amendments to the claims are supported at least in 
the summary of the specification as originally filed. No claims have been 
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